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ABSTRACT: 

A semiconductor storage device connected to the host system through the general purpose 
interface, including a semiconductor storage media module (1 ) and a controller module (2), in 
vsrhich the controller module (2) consists of a general purpose interface control module (21), a 
microprocessor and control module (22). Various device dass protocols can be realized at the 
interface application level of the semiconductor storage device, which makes it possible to 
simulate and realize the storage functions of various storage disks. One or a plurality of storage 
spaces are opened up in the semiconductor storage media and one or a plurality of storage disks 
are supported by the same device; furthermore, the device supports hot plug and play and it is 
removable. 
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(54) A multifunction semiconductor storage device and a method for booting-up computer host 



(57) A semiconductor storage device connected to 
the host system through the general purpose interface, 
including a semiconductor storage media module (1) 
and a controlier module (2). in which the controller mod- 
ule (2) consists of a general purpose interface control 
module (21 ), a microprocessor and control module (22). 
Various device class protocols can be realized at the in- 



terface application level of the semiconductor storage 
device, which makes it possible to simulate and realize 
the storage functions of various storage disks. One or a 
plurality of storage spaces are opened up in the semi- 
conductor storage media and one or a plurality of stor- 
age disks are supported by the same device; further- 
more, the device supports hot plug and play and it is 
removable. 
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Description 

BACKGROUND OF THE INVENTION 

FIELD OF THE INVENTION 

[0001 ] The present invention relates to a multifunction 
semiconductor storage device using semiconductor 
storage media, in particular, a multifunction semicon- 
ductor memory device connected to the host computer 
via the general-purpose interface. 

DESCRIPTION OF THE REU«"ED ART 

[0002] The semiconductor storage media is a semi- 
conductor chip for storing data; the chip can receive writ- 
ing commands and data and then write them into the 
memory chip. The chip can also receive external read 
commands and read the data stored on the chip and 
output the data. In addition, the chip also supports other 
commands such as erasure and resetting commands. 
These kinds of semiconductor storage devices of this 
kind Include flash memory, EEPROM, FRAM, DRAM, 
SRAM, SDRAM or MRAM but not are restricted to them. 
Compared with conventional magnetic and optic mem- 
ory devices, the present semiconductor memory device 
has the features of small volume, less weight, large stor- 
age capacity, and higher reliability and low power con- 
sumption. In addition, it does not require any specific 
mechanism to drive It. For example, in Chinese patent 
No. ZL 00114081 .7"Fuli Electronic External Flash Mem- 
ory Technique and Devtee**, It discloses an external 
memory device using a flash memory device, wherein 
a semiconductor storage media and general purpose In- 
terface are used so as to realize external removable disk 
without extemal drive power supply; it supports hot 
dock/undock and plug-and-play function and it is not 
necessary to turn off the computer when doing plug and 
play. Furthermore, the removable memory has higher 
speed of data access and larger capacity than a floppy 
disk. In addition, it also has the advantages of small vol- 
ume, easy portability, and indefectible. It can be applied 
to data processing systems supporting universal inter- 
face channels such as USB (universal serial bus) and 
IEEE1394. 

[0003] Traditional floppy diskettes and floppy disk 
drives play less and less roles, especially after the 
above-mentioned external flash memory device had 
been Invented, which makes it possible the exchange 
of data without floppy diskettes and floppy disk drives. 
However, computer users today still find that floppy dis- 
kettes and floppy disk drives are indispensable. One of 
the reasons is that the external flash memory disk before 
this invention above does not support the booting of the 
computer. When the computer system is Infected with a 
viais or destroyed by the virus, an empty boot disk is 
needed to restart the computer through the BIOS (Basic 
Input and Output System). Desktop computers equip 



built in floppy disk drives in order to boot the system but 
it increases the volume and weight of the host system 
as well as the cost. Because of the bulklness of the flop- 
py disk drives, the majority of the uttra-thin laptop com- 

s puters do not have built-in floppy disk drives so as to 
reduce the volume and weight of the computer. Howev- 
er, the users still have to install very expensive USB ex- 
ternal floppy disk drives in order to boot the system and 
it increases the cost of the users and causes inconven- 

10 ience In use. 

[0004] Although the cun^ent flash memory devces 
such as DiskOnChip support the booting of the compu- 
ter, they do not support hot plug in/out and are not re- 
movable because they are built in the computer. As a 

15 result, when the system software of the computer is de- 
stroyed by the virus, it cannot be restarted through Dis- 
kOnChip. Thus it is a restriction to the application of the 
devtoe. 

[0005] The current existing removable semiconductor 
20 storage devices can only be used on the driver software 
installed in the operating system of the computer but 
cannot be recognized and controlled by the BIOS of the 
computer, thus they cannot be used as the boot devk:e 
of the system. 

25 [0006] Most of the BIOS manufacturers have pro- 
duced the BIOS capable of supporting the boot function 
of the extemal USB floppy disk drive, such as the BIOS 
of AWARD. Furthermore, many of the malnboard pro- 
ducers have adopted the above-mentioned BIOS, for 

30 example, ASUS motherboard, which lays the foundation 
for the large-scale use of the present invention. 

SUMMARY OF THE INVENTION 

35 [0007] in view of the deficiencies of the conventional 
storage devices, an object of the present invention is to 
provide a semiconductor storage device capable of sim- 
ulating and realizing the functions of various storage 
disks as well as acting as the removable boot device of 

40 the computer system. 

[0008] The present invention provide a multifunction 
semk;onductor storage device capable of hot plug in/out 
and being removable connected to the host system 
through the general purpose interface, including a sem- 

45 conductor storage media module and a controller mod- 
ule, wherein the controller module comprises a general 
purpose Interface control module, a microprocessor and 
control module, said semiconductor storage device can 
realize the devk:e class protocol of the floppy disk drive, 

so simulate and Implement the storing function of the floppy 
diskette woridng on the floppy disk drive, or realize the 
devk:e dass protocol of the CD-ROM drive, simulate 
and implement the storing function of the CO-ROM 
working on the CD-ROM drive, or realize the devk:e 

55 class protocol of the ZIP disk, simulate and Implement 
the storing function of the ZIP disk, or realize the device 
class protocol of the MO disk, simulate and implement 
the storing function of the MO disk. 
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[0009] The present invention further provides a meth- 
od for booting-up computer using the multifunction sem- 
iconductor storage device, comprising the steps of: stor- 
ing the boot program of the operating system and oper- 
ating system programs Into the multifunction semicon- 
ductor storage device; connecting the multifunction 
semiconductor storage device with the computer host 
system through the general purpose interface: identify- 
ing the general purpose Interface, and controlling and 
reading/writing the multifunction semiconductor storage 
device based on BIOS after powered up the computer 
host system; and loading the boot program of the oper- 
ating system and operating system programs stored in 
the multifunction semiconductor storage device to com- 
puter host system for achieving computer booting-up. 
[001 0] The protocols supported by the present semi- 
conductor storage device are UFI protocol, SFF80201 
protocol, SFF80701 protocol, SCSI Transparent Com- 
mand Set protocol, Reduced Blocic Commands (RBC) 
T10 Project 1240-D protocol, ZIP disic protocol and MO 
protocol. 

[001 1] The semiconductorstorage media modulecor- 
responds to a storage space or it can be divided into at 
least two storage spaces with each con^espondlng to a 
storage dlsi(. Preferably, each of the storage spaces can 
be further divided into smaller spaces such as a data 
area for storing data and a special infomiation area for 
storing a special infomiation, in which the special infor- 
mation contains infomiation related to the storage disk, 
the password and the digital signature of the user, and 
so on. 

[0012] The semiconductor storage device according 
to the present invention can be recognized, controlled 
and accessed by the BIOS of the host system. The sem- 
iconductor storage media module can store the boot 
program of the operating system and the operating sys- 
tem programs. When the BIOS of the host computer 
platfonm is powered up, the system then loads the boot 
program of the operating system and the operating sys- 
tem programs from the semiconductor storage media 
module so as to realize the booting of the host system. 
[0013] Preferably, In the semiconductor storage de- 
vice according to the present invention, the semicon- 
ductor storage media module can store the driver pro- 
gram of the semiconductor storage device itself so as 
to realize the function of storing the driver program in 
itself. 

[0014] Preferably, the semiconductor storage device 
according to the present Invention further includes the 
write protect switch capable of offering physical protec- 
tion to the semiconductor storage media module so as 
to preventing the contents from being over rewritten or 
erased. The write protect switch is electrically connect- 
ed to the microprocessor and control module electrical- 
ly. 

[0015] Preferably, the semiconductor storage device 
according to the present invention further includes an 
LED indicatorp which comprises one or more indicator 



parts, which can show the status of the semiconductor 
storage device. The LED indicator is electrically con- 
nected to the microprocessor and control module elec- 
trically. 

s [001 6] In the semiconductorstorage device according 
to the present invention, preferably, the controller mod- 
ule further comprises a buffer module, and the buffer 
module is a static random access memory (SRAM), and 
is electrically connected to the mbroprocessor and con- 

10 trol module. 

[0017] In the semiconductor storage device in the 
present invention, preferably, the semiconductor stor- 
age media module further comprises buffer area. 
[0018] In the sembonductor storage device according 

IS to the present invention, preferably, the semiconductor 
storage media module further comprises a special infor- 
mation area for storing relevant data, password and the 
digital signature of the user. There can be no special 
infomiation area in the device. 

20 [001 9] Preferably, the semiconductor storage device 
in the present invention further includes a storage disk 
selection switch for selecting at least a storage disk from 
all of the storage disks, so that the selected storage disk 
can be recognized, controlled and accessed by the host 

25 system.. 

[0020] The present invention provides a unique de- 
sign so as to realize various device class protocols at 
the interface application level of the semk^onductor stor- 
age device, and it can simulate and implement the var- 

30 ious storage capacities of the storage disks. One or 
more storage spaces are provided in the semiconductor 
storage media, and one or more storage disk functions 
are supported in the same device. The present invention 
fully realizes the storage function of the external floppy 

35 drive and the floppy diskette using the general purpose 
Interface, making it possible the entire substitution of 
floppy diskette and floppy disk drives. The semiconduc- 
tor storage device in the present invention has a smaller 
size, lightweight, a more stable performance and a high- 

<o er reliability than those of the conventional semiconduc- 
tor storage device, and It supports hot plug in/out and is 
removable. Accordingly, it is possible to make the host 
system being smaller in size and being portable. Fur- 
thermore, It effectively reduces the costs of the compu- 

45 ter. 

BRIEF DESCRIPTION OF THE DRAWINGS 
[0021] 

50 

Rg. 1 is a block diagram of the functions of the multi- 
purpose hardware used in the semiconductor stor- 
age device of the present invention; 
Rg. 2 is a block diagram of the functions of the hard- 
55 ware using the USB Interface and the flash memory 
in an embodiment according to the present Inven- 
tion; 

Rg. 3 is a block diagram of the functions of the hard- 
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ware using the IEEE1394 interface and the flash 
memory in an embodiment according to the present 
invention: 

Fig. 4 shows the storage spaces allocation of the 
semiconductor storage device in an embodiment of 
the present invention; 

Rg. 5 is a working flow chart of the embodiment 
shown in Fig. 2; 

Rg. 6A, B. C, D shows the circuits schematics of 
the embodiment shown in Fig. 2 according the 
present invention, respectively. 

DETAILED DESCRIPTION OF INVENTION 

[0022] Fig. 1 is a blocl< diagram of the functions of the 
multi-purpose hardware in an embodiment of the 
present invention. The semiconductor storage device is 
connected to the host computer via the general-purpose 
Interface connecting cable or a connecting plug or 
through wireless connection mode. The semiconductor 
storage device comprises a semiconductor storage me- 
dia module 1, a controller module 2, a write protect 
switch 3, a storage disic selection switch 4 and a LED 
indicator 5, wherein the controller module comprises a 
general purpose Interface control module 21 . a micro- 
processor and control module 22, and a buffer module 
23. 

[0023] The semiconductor storage media module 1 
consists of one or more semiconductor storage media 
chips, the semiconductor storage media can be a flash 
memory, an EEPROI\/l. FRAM. SRAM. DRAM. SDRAM 
and a M RAM but be not restricted to them, which is con- 
nected through the current addressing method for stor- 
ing data. The semiconductor storage media module 1 
corresponds to either one storage space or at least two 
storage spaces. The semiconductor storage media 
module 1 can store the driver program of the semicon- 
ductor storage device itself so as to realize the function 
of storing the driver program In itself. 
[0024] The controller module 2 executes the initializa- 
tion of the device, the control of the device, the initiali- 
zation and control of the general purpose interface, the 
reception^ the interpret and Implementation of the com- 
mands sent from the host computer, the storage of the 
data to the semiconductor storage module 1 or the read- 
ing of the data from the semiconductor storage module 
1 and the return of the executing result to the host sys- 
tem through the general purpose Interface. 
[0025] The general purpose interface control module 
21 of the controller module 2 executes the connection 
with the host system, interprets, converts, controls and 
transmits the general purpose interface protocol. The 
general purpose interface can be either wired general 
purpose interface, including USB interface. IEEE1394 
interface, or wireless general purpose Interface, Includ- 
ing Bluetooth interface, IrOA infrared interface, 
HomeRF interface, IEEE802.1ta interface, 
IEEE802.11 b interface but be not restricted to them. 



[0026] The microprocessor and control module 22 in- 
itializes the general purpose interface control module 
21 . reads the status of the storage disk selection switch 
4. detemiines the device class protocol implementing 

5 the floppy disk drive In accordance with the status of the 
storage disk selection switch 4, simulates and realizes 
the storage function of the floppy diskette working on 
the floppy disk drive; or it realizes the device class pro- 
tocol of the hard disk, simulates and Implements the 

ro storage function of the hard disk, or it realizes the device 
class protocol of the Zl P disk, simulates and implements 
the storage function of the ZIP disk, or it realizes the 
devk^e class protocol of the MO disk, simulates and Im- 
plements the storage function of the MO disk; further- 

15 more, it can support hot plug in/out and is removable. 
The device dass protocol supported by the storage disk 
is UFI protocol, SFF80201 protocol, SFF80701 proto- 
col, SCSI Transparent Command Set protocol, Re- 
duced Block Commands (RBC) TIG Project1240-D pro- 

^ tocol, ZIP disk protocol, and MO disk protocol. The stor- 
age disk selection switch 4 can select one storage disk 
or more disks at the same time. 
[0027] One and more storage disks in the devk» can 
store other driver program for the other storage disks of 

25 the device according to the present Invention and realize 
the function of the storing Itself driver program. 
[0028] The mbroprocessor and control nfK)dule 22 
has the functions of: 

30 a. initializing the semiconductor storage module 
and detecting the capacity, the manufacturer and 
the quantity of the storage chip In the semiconduc- 
tor storage module; 

b. receiving control commands based on the gen- 
35 eral purpose interface protocol and interpreting and 

executing the control commands and returning the 
results of executions to the host system through the 
general purpose interface; 

c. receh/Ing the simulated storage disk device class 
40 protocol, Interpreting and executing related com- 
mands and returning the results of executions to the 
host system through general purpose interface; the 
related commands include reading data, writing da- 
ta, the reading device information and reading de- 

45 vice capacity; 

d. receiving customized storage disk device class 
protocol. Interpreting and executing corresponding 
commands and returning the results of executions 
to the host system through the general purpose in- 

50 terface; the corresponding commands include 
reading data, writing data, reading d6vk:e infomia- 
tlon and read devicing capacity but be not restricted 
to them; 

e. writing data into the semiconductor storage de- 
55 vtee or reading data from the semiconductor device; 

when reading data, the LED Indicator blinks; when 
executing writing operation, the status of the write 
protect switch will be dete^ed, and If the switch is 
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in the status of the write-protection, writing request 
will be refused and the operation failure will be in- 
formed to the host computer: 

f. converting the logical addresses In the storage 
device defined on the host system into actual the 
storage chip number and physical addresses of the 
storage chip; 

g. when the connection between the microproces- 
sor and control module 22 and the host system is 
established^ the LED Indicator Is lighted on. 

[0029] Since the difference between the storage 
modes of the semiconductor storage media, the buffer 
module 23 may be not a necessary device In certain cas- 
es; before the erasure of some data block of the semi- 
conductor storage module, the buffer module is used to 
save the original data of the storage units and write the 
data Into the buffer and finally write the data of the buffer 
back into the semiconductor storage media. The buffer 
module can be the SRAM and some part of the semi- 
conductor storage module can also function as the buff- 
er. As a result of the difference in the storage media, the 
operation of erasure can be optional. 
[0030] The functions of the controller module 2 can 
be realized by using one or more Integrated circuit chips, 
and the chips can be an ASIC, or an SOC or a monolithic 
processor with firmware. 

[0031 ] Rg. 2 is the block diagram of the flash memory 
with the USB interface in an embodiment according to 
the present Invention. 

[0032] In the embodiment, the USB interface Is used 
as the general-purpose interface and the flash memory 
is used as the semiconductor storage media. In the em- 
bodiment, a flash memory module 11, a controller mod- 
ule 20, a write protect switch 3, a storage disk selection 
switch 4, a LED ind»ator5 and so on are included. The 
controller module includes a USB interface controller 
module 201 , a microprocessor and control module 202 
and an SRAM buffer module 203. 
[0033] The flash memory module 1 1 is formed with ei- 
ther one or a plurality of semiconductor flash memory 
chips, and is connected in accordance to the addressing 
method for storing data. 

[0034] The controller module 20 executes the initiali- 
zation of the device, the control over the device, the in- 
itialization and the control of the USB interface, the re- 
ception of the commands and data from the host sys- 
tem, the interpretation and the execution of the conv 
mands from the host system, writing data to the flash 
memory module 1 1 or reading data from the flash mem- 
ory module and returning the results of the execution to 
the host system through the USB interface. 
[0035] The USB interface control module 201 in the 
controller module establishes a USB connection with 
the host system that interprets, converts, controls and 
transmits the USB protocol. 

[0036] The microprocessor and control module 202 
initializes the USB interface control module 202, reads 



the status of the storage disk selection switch 4, and 
detemnines whether it supports the floppy disk drive de- 
vtee class protocol such as the UFl. the SFF80801 pro- 
tocol or the large capacity storage disk device protocol 
5 such as the SFF80701, the SCSI Transparent Com- 
mand Set and the Reduce Block Commands (RBC) T1 0 
Project 1240-D protocols based on the status of the 
switch 4. 

[0037] The microprocessor and control module 202 

10 have the similar functions with the above mentioned mi- 
croprocessor and control module 22, such as initializing 
the flash memory module, detecting the capacity, the 
manufacturer and the quantity of the flash memoiy 
chips, etc. The microprocessor and control module 202 

15 receives the standard control commands based on the 
USB protocol, interprets and executes the control com- 
mands and returns the results of the execution to the 
host system through USB interface. The standard USB 
commands include the following: GET_STATUS, 

20 CLEAR.FEATURE,SET^FEATURE,SET_ADDRESS, 
GET^DESCRIPTOR, SET^DESCRIPTOR, GET. 
CONFIGURATION, SET_CONFIGURATION, GET IN- 
TERFACE, SETJNTERFACE, SYNCH.FRAME, etc.. 
but be not restricted to them. 

25 [0038] The embodiment as shown In Fig. 2 has two 
working statuses: 

1 . The status of the simulated floppy disk drive and the 
floppy diskette 

30 

[0039] When the semiconductor storage device in the 
embodiment according to the present invention is In the 
status of the simulated floppy disk drive and floppy dis- 
kette, the device supports the floppy disk drive device 

35 class UFI(USB Floppy Interface) protocol. The micro- 
processor and control module 202 communteates with 
the host system through USB interface in conformity 
with the CBI (Control/Bulk/Interrupt) transport protocol. 
According to the CBI protocol, the microprocessor and 

40 control module 202 unpacks the data packets received 

' from the USB interface, extracts the floppy disk drive 
devk:e class UFl commands from the unpacked data, 
then executes the related device dass commands, 
packs the results of the execution or the status infomna- 

45 tion according to the CBI protocol, and returns the re- 
sults to the host system through the USB interface. 
[0040] The device class commands related to the 
floppy disk drive include Fomiat Unit, Inquiry, Start/Stop, 
Mode Select, Mode Sense, Prevent/Allow Media Re- 

so moval, Read (10), Read (1 2), Read Capacity, Read For- 
mat Capacity, Request Sense, Rezero track. Seek (10), 
Send Diagnostic, Test Unit Ready, Verify, Write (10), 
Write (12), Write and Verify, etc.. but not restricted to 
them. 

55 [0041] The explanation of several principal com- 
mands used in the embodiment of the present inventton 
will be described hereafter: 

[0042] The inquiry command is used to inquire the re- 
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lated parameters and configuration infomnation of the 
device, the host system or the driver program of the BI- 
OS conflgure the device with the above related param- 
eters and configuration information white the device is 
turned on or reset. The control module returns the con- 
figuration infomnatlon of the device to the host computer 
according to the UFI protocol and sets the data bit for 
Peripheral Device Class in the configuration infomiation 
as Direct-access device. 

[0043] The Mode Sense command Is used to pemilt 
the device to notify the storage media class and the de- 
vice parameters to the host computer. There is one bit 
of Media Class Codes in the information notified to the 
host computer. The code is used to determine the ca- 
pacity and class of the device. As the capacity of the 
simulated floppy disl(ette Is 1 .44MB, the defined code is 
0x96 (hexadecimai). 

[0044] The Read Capacity command Is used to re- 
quest the device to notify the capacity of the storage 
disk. The data returned from the device show that the 
total capacity is 1 .44MB. 

[0045] The Read Format Capacity command pemiits 
the host system to request the possible capacity of the 
storage disk to be formatted and only one answer from 
the device Is 1 .44MB. 

[0046] The Test Unit Ready command pemnits the 
host system to test whether the device is ready, and the 
answerf rom the device is ready if it is in the ready status. 
[0047] The Read 1 0 command is used to request the 
device to read data at a certain logical address in the 
storage disk and retums the read data to the host sys- 
tem. The control module then calculates the number of 
chips in whk;h the logical address is located and the 
physical addresses in the chip based on the logical ad- 
dress and the capacities of various storage chips. Then 
it sends reading data command and address infonna- 
tion to the flash memory, reads data from the flash menv 
ory, and sends the data to the host system. When the 
control module is reading and transmitting data, the LED 
indteator 5 flashes. 

[0048] The write 10 is used to request the device to 
receive data from the host system, then write the re- 
ceived data at a certain logical address in the storage 
disk; the control module first detects the write protection 
switch, the control module refuses the write operation 
from the host computer and reports failure of write op- 
eration when the write protect switch Is in write protect- 
ing status. When the switch is not in the write protect 
status, the control module calculates the chip number 
in which the logical address is kx:ated, the physical ad- 
dress and the block address in the chip based on the 
logical address and the capacities of various storage 
chips. When data are written Into an address in the flash 
memory, the block containing the address should firstly 
be erased, thus the original data will be lost In the block; 
therefore, the data stored in the block address should 
be read out and written into the buffer module of the 
SRAM. Then, the data are written Into the SRAM buffer 



module according to the relative address in the block. 
Next, the con'esponding block In the flash memory 
erased and the data block In the SRAM buffer module 
Is written into the corresponding block of the flash mem- 
5 ory, and the entire write operation is completed. The 
control module keeps the LED indicator 5 flashing when 
receiving and writing data. 

[0049] The other woridng status of the embodiment 
as shown In Fig. 2 Is described hereafter. 

10 

2. The Status of the Large Capacity Storage Disk 

[0050] The large capacity storage disk can be a sim- 
ulated hard disk, a simulated CD-ROM, a simulated ZIP 

15 disk and a simulated MO disk, etc. 

[0051] When the semk:onductor storage device of the 
embodiment according to the present Invention is In the 
working status of the large capacity storage disk, the de- 
vk:e supports SFF80701 device class protocol. The mi- 

20 croprocessor and control module 202 communicates 
with the host system through USB interiace according 
to the BulkOnly transport protocol. The control module 
202 unpack the data packet from the USB interface ac- 
cording to the BulkOnly transport protocol, extracts the 

25 SFF80701 class commands from the unpacked data, 
executes the corresponding commands, packs the re- 
sults of the execution for the corresponding command, 
and sends them to the host system through USB Inter- 
face. The SFF80701 class commands include Fomnat 

30 Unit, Inquiry, Mode Select, Mode Sense, Prevent/Allow 
Media Removal, Read (10), Read (12), Read Capacity, 
Read Fomnat Capacities, Request Sense. Seek. Start 
Stop Unit. Test Unit Ready. Verify, Write (10). Write (12), 
Write and Verify, etc. 

35 [0052] The explanation of several principal com- 
mands used In the embodiment of the present invention 
will be described hereafter: 

[0053] The Read Capacity command is used to re- 
quest the host system to get the capacity of the storage 

40 disk of the device. The control module caknjiates the to- 
tal capacity of the storage module according to the mod- 
el and quantity of the flash memory chips detected. The 
capacity of the large capacity storage disk is obtained 
by subtracting a 1 .44MB and the capacity occupied by 

^5 other special infomnation from the total capacity. The ob- 
tained capacity value is returned to the host system. 
[0054] The Read 1 0 command Is used to request the 
devce to read data at a ceriain logical address in the 
storage disk and retums the read data to the host sys- 

so tern. The control module firstly adds 1 .44MB (floppy ca- 
pacity) to the togteal address, and calculates the number 
of the chips in where the logical address is located and 
the physical addresses in the chip based on the logical 
address and the capacities of various storage chips. 

5s TTien it sends the read data command and address to 
the flash memory, reads data from the flash memory, 
and sends the data to the host system. When the control 
module is 'reading and transmitting data, the LED indi- 
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cator 5 flashes. 

[0055] The write 10 is used to request the device to 
receive data from the host system and writes the re- 
ceived data at a certain ioglcal address in the storage 
disk; the control module firstly detects the write protec- 
tion switch. The control module refuses the write oper- 
ation from the host computer and reports failure of write 
operation when the write protection switch is in write pro- 
tection status. If the switch is not in the write protection 
status, the control module first add 1 .44I\^B of floppy ca- 
pacity to the logical address, and calculates the chip 
number in where the logical address Is located, and the 
physical address and the block address in the chip 
based on the logical address and the capacities of var- 
ious storage chips. When data are written in an address 
in the flash memory, the block containing the address 
should firstly be erased, thus the original data will be lost 
in the block; therefore, the data stored In the block ad- 
dress should be read out and written into the buffer mod- 
ule of the SRAM. Then, the data are written into the 
SRAM buffer module according to the relative address 
in the block. Next, the corresponding block in the flash 
memory is erased and the data block In the SRAM buffer 
module Is written into the corresponding block in the 
flash memory, and the entire write operation is complet- 
ed. The control module keeps the LED indicators flash- 
ing when receiving and writing data. 
[0056] When the microprocessor and control module 
22 establishes a connection with the host system, the 
LED indicator 5 is turned on. 
[0057] Fig. 3 shows another embodiment of the sem- 
iconductor storage device of another embodiment ac- 
cording to the present invention. It is a block diagram of 
the hardware of the 1EEE1 394 interface and flash mem- 
ory. In the embodiment, the general-purpose interface 
is an IEEE1394 interface and the semiconductor stor- 
age media is the flash memory. It includes a flash mem- 
ory module 11 , a controller module 200, a write protec- 
tion switch 3, a storage disk selection switch 4, and a 
LED Indicator S.The controller module 200 Includes an 
IEEE1394 interface control module 211 . a microproces- 
sor and control module 212, and an SRAM buffer mod- 
ule 213. 

[0058] The flash memory module 11 is fomned with 
one or a plurality of semiconductor flash memory chips 
and is connected by the conventional addressing mode 
so as to store data. 

[0059] The controller module 200 executes the initial- 
ization of the device, the control over the device, the in- 
itialization and the control of the lEEEl 394 Interiece, the 
reception of the comnr^nds and data from the host sys- 
tem, the interpretation and the execution of the com- 
mands from the host system, writing data to the flash 
memory module 1 1 or reading data from the flash mem- 
ory module and returning the results of the execution to 
the host system through the IEEE1394 interiace. 
[0060] The IEEE1394 interface control module 211 in 
the controller module establishes conne^on with the 



IEEE1 394 Interface of the host system, and handles the 
interpretation, conversion, control and transport of the 
IEEE1394 protocol. 

[0061] The microprocessor and control module 212 
5 initializes the IEEE1394 interiace control module 211, 
reads the status of the storage disk selection switch 4 
and thereby detemnines whether it supports the floppy 
disk drive devk:e class protocol such as SFF80701 , SC- 
SI Transparent Convnand Set and Reduce Block Com- 
10 mands (RBC) T1 0 Project 1 240-D protocols, but not re- 
stricted to them. 

[0062] Further, the mnroprocessor and control mod- 
ule 21 2 also initializes the flash memory module, detects 
the capacity, the manufacturer and the quantity of the 

15 flash memory chips, etc. The mteroprocessor and con- 
trol module 212 receives the standard control com- 
mands based on the IEEE1394 interface protocol. Inter- 
prets and executes the control commands, and retums 
the results of execution for the commands to the host 

^ system through the IEEE1 394 interface. 

[0063] The embodiment as shown In Fig. 3 has two 
working statuses: 

1 . The status of the simulated floppy disk drive and the 
25 floppy diskette 

[0064] When the semteonductor storage device is in 
the status of the simulated floppy disk drive and floppy 
diskette, the device suppo rts the floppy disk drive device 

30 class UFI protocol. The microprocessor and control 
module 212 receives the data from the USB interface, 
extracts the floppy disk drive device class UFI com- 
mands from the data packets, then executes the related 
devbe class commands, and retums the results to the 

35 host system through the USB interface. 

[0065] The device class commands related to the 
floppy disk drive include Fornnat Unit, Inquiry, Start/Stop, 
Mode Select, Mode Sense, Prevent/Allow Media Re- 
moval, Read (10), Read (12), Read Capacity. Read For- 

40 mat Capacity. Request Sense, Rezero track. Seek (1 0), 
Send Diagnostic, Test Unit Ready, Verify, Write (10), 
Write (12), Write and Verify, etc., but not restricted to 
them. The explanation of several principal commands 
used In the embodiment of the present invention will be 

45 described hereafter: 

[0066] The inquiry command is used to inquire the re- 
lated parameters and configuration information of the 
devfce, the host system or the driver program of the BI- 
OS configure the device with the above related param- 

50 eters and configuration Infomiatlon while the devtee Is 
turned on or reset. The control module returns the con- 
figuration inf omiation of the device to the host computer 
according to the UFI protocol and sets the data bit for 
Peripheral Device Class in the configuration infonnation 

55 as Direct-access devtee. 

[0067] The Mode Sense command is used to permit 
the device to notify the storage media type and the de- 
vk:e parameters to the host computer. There is one bit 
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of Media Type Codes in the information notified to the 
host computer. The code Is used to determine the ca- 
pacity and type of the device. As the capacity of the sinv 
ulated floppy diskette is 1.44MBt the defined code is 
0x96 (hexadecimal). 5 
[0088] The Read Capacity command is used to re- 
quest the device to notify the capacity of the storage 
disk. The data retumed from the device show that the 
total capacity is 1 .44MB. 

[0069] The Read Format Capacity command permits io 
the host system to request the possible capacity of the 
storage disk to be formatted and only one answer from 
the device is 1.44MB. 

[0070] The Test Unit Ready command permits the 
host system to test whether the device is ready, and the 
answerfrom the device is ready if it Is in the ready status. 
[0071] The Read 1 0 command Is used to request the 
device to read data at a certain logical address In the 
storage disk and returns the read data to the host sys- 
tem. The control module then calculates the number of 
the chip in where the logical address is located and the 
physical addresses In the chip based on the logcal ad- 
dress and the capacities of various storage chips. Then 
it sends the read data command and address Infomna- 
tion to the flash memory and reads data from the flash 
memory, and sends the data to the host system. When 
the control module is reading and transmitting data, the 
LED indicator 5 fleshes. 

[0072] The write 10 is used to request the device to 
receive data from the host system, then write the re- 
ceived data at a certain logical address in the storage 
disk. The control module first detects the write protection 
switch, and the control module refuses the write opera- 
tion from the host computer and reports failure of write 
operation when the write protection switch Is in write pro- 
tection status. When the switch is not In the write pro- 
tection status, the control module calculates the chip 
number in which the logical address is located, and the 
physical address and the block address in the chip 
based on the logical address and the capacities of var- 
ious storage chips. When data are written into an ad- 
dress in the flash memory, the block containing the ad- 
dress should firstly be erased, thus the original data will 
be lost In the block; therefore, the data stored in the 
block address should be read out and written into the 
buffer module of the SRAM. Then, the data are written 
Into the SRAM buffer module according to the relative 
address in the block. Next, the corresponding block of 
the flash memory Is erased and the data block in the 
SRAM buffer module is written Into the con^esponding 
block in the flash memory, and the entire write operation 
is completed. The control module keeps the LED indi- 
cator 5 flashing when receiving and writing data. The 
other working status of the embodiment as shown in Fig. 
3 Is described hereafter: 



2. The Status of the Large Capacity Storage Disk 

[0073] When the semteonductor storage devtee of the 
embodiment is in the wortdng status of the large capacity 
storage disk, the devtee supports SFF80701 devtee 
class protocol. The microprocessor and control module 
212 extracts the SFF80701 type commands from the re- 
ceived data through IEEE1394 Interface, executes the 
related command, sends the result of the executton or 
a status Infomiatlon to the host system through 
1EEE1394 interface. The SFF80701 class commands 
Include Fomiat Unit, Inquiry, Mode Select. Mode Sense, 
Prevent/Allow Media Removal, Read (10), Read (12), 
Read Capacity, Read Format Capacities. Request 
Sense, Seek, Start Stop Unit, Test Unit Ready, Verify, 
Write (10), Write (12), Write and Verify, etc.. but not re- 
stricted to them. 

[0074] The explanation of several principal com- 
mands used In the embodiment of the present lnventk}n 
will be described hereafter: 

[0075] The Read Capacity comn^nd is used to re- 
quest the host system to get the capacity of the storage 
disk of the device. The control module cak:uiates the to- 
tal capacity of the storage module according to the mod- 
el and quantity of the flash memory chips detected. The 
capacity of the large capacity storage disk is obtained 
by subtracting 1 .44MB and the capacity occupied by 
other special Information from the general (total) capac- 
ity. The obtained capacity value is returned to the host 
system. 

[0078] The Read 1 0 command is used to request the 
devk:e to read data at a certain logical address in the 
storage disk and retums the read data to the host sys- 
tem. The control module firstly adds 1 .44MB (floppy ca- 
pacity) to the logical address, and calculates the number 
of chips In which the logical address Is located and the 
physk:al addresses in the chip based on the k>gical ad- 
dress and the capacities of various storage chips. Then 
it sends the read data command and address Infomna- 
tion to the flash memory and reads data from the flash 
memory, and sends the data to the host system. When 
the control module is reading and transmitting data, the 
LED indicator 5 flashes. 

[0077] The write 10 is used to request the devrce to 
receive data frtsm the host system, then write the re- 
ceived data at a certain logical address in the storage 
disk; the control module firstly detects the write protec- 
tion switch. The control module refuses the write oper- 
ation from the host computer and reports failure of write 
operation when the write protection switch Is in write pro- 
tection status. If the switch is not in the write protection 
status, the control module first add 1 .44MB of floppy ca- 
pacity to the logical address, and calculates the chip 
number in whtoh the bgteai address Is tocated. and the 
physteal address and the block address in the chip 
based on the logteal address and the capacities of var- 
ious storage chips. When data ere written into an ad- 
dress of the flash memory, the block containing the ad- 
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dress should firstly be erased, thus the original data will 
be lost In the block; therefore, the data stored in the 
block address should be read out and written Into the 
buffer module of the SRAM. Then, the data are written 
into the SRAM buffer module according to the relative 
address in the block. Next, the con'esponding block in 
the flash memory is erased and the data block in the 
SRAM buffer module is written into the con^esponding 
block of the flash memory, and the entire write operation 
Is completed. The control module keeps the LED Indi- 
cator 5 flashing when receiving and writing data. 
[0078] When the microprocessor and control module 
212 establishes a connection with the host system, the 
LED indicator 5 is turned on. Fig. 4 shows the allocation 
of the storage spaces of the semiconductor storage 
module. The entire storage module includes N storage 
spaces with each corresponding to one storage disk. Al- 
ternatively, the storage module can contain a data buffer 
area or not, and can contain a special infomnation area 
for the entire storage device or not. Each of the storage 
spaces includes a data area and a special information 
area. Atternativety, each of the storage spaces may not 
Include the special infonmation area. The data buffer ar- 
ea functions as the buffer module 23 (see Pig. 1). the 
entire special infomnation area of the storage device can 
be used to store information about the storage device, 
such as the record of the bad blocks of the flash memory, 
the passwords and the digital signatures of the users, 
etc., but not restricted to them. 
[0079] Fig. 5 is a working flow chart of the device of 
the embodiment in Fig. 2. 

[0080] In step 1 , it establishes connection with the 
USB interface of the host system from where it acquires 
electrical power. At this time, the microprocessor and 
control module 202 firstly initializes the microprocessor 
and control module 202, including the setting of the dif- 
ferent registers and of the operation frequencies. 
[0081] In step 2, the microprocessor and control mod- 
ule 202 detects the storage module of the flash memory 
and obtains the model, capacity, manufacturer and total 
number of the storage chips and saves the results of the 
detection. 

[0082] In step 3, the microprocessor and control mod- 
ule 202 reads the special infomnation of the storage de- 
vice, in which the bad block table is Included but not re- 
stricted It. 

[0083] In step 4, the microprocessor and control mod- 
ule 202 Initializes the USB interface controller. 
[0084] In step 5, the microprocessor and control mod- 
ule 202 receives the USB control commands from the 
host system and executes related connmands and re- 
turns the results of execution. When the request device 
description command is executed, the control module 
detects the "floppy disk drive" and "large capacity stor- 
age disk" status switch and detemfilnes which status the 
device is in, that is, which device dass protocol and 
transport protocol are supported by the device. The con- 
trol module then informs to the host computerthe device 



class protocol and transport protocol supported by the 
device. When It is in the "floppy disk drive" status, the 
devtee supports the UFI device dass protocol and the 
CBI transport protocol, and when it is in the "large ca- 
5 pacity storage disk" status, the device supports the 
SFF80701 device dass protocol and the BulkOnly pro- 
tocol. 

[0085] In step 6. the host computer detemiines wheth- 
er the storage devtee Is a "f toppy disk drive' or a "large 

10 capacity storage disk" based on the retumed device 
class protocol and transport protocol. If the device is in 
the "floppy disk drive" status, the host computer then 
sends UFI class device commands to the device based 
on the CBI transport protocol in step 7, and if the device 

15 is In the "large capacity storage disk", the host computer 
then sends SFF80701 type device commands to the de- 
vice based on the BulkOnly transport protocol in step 9. 
If the device Is In the 'lloppy disk drive" status, the con- 
trol module then receives UFI class commands from the 

20 host system according to the CBI transport protocol, In- 
terprets and executes the related commands, and re- 
turns the results of the executing or the status message 
to the host system in the fomnat of the CBI transport pro- 
tocol in step 8. And if the device is In the status of "large 

2s capacity storage disk", the control module then receives 
the SFF80701 class commands from the host system 
according to the BulkOnly transport protocol, interprets 
and executes the related commands, and sends the re- 
sults of the executing or the status message to the host 

30 system in the format of the BulkOnly transport protocol 
in step 10. 

[0086] Once the power of the host computer is off or 
the device is removed from the host system, the device 
stops woridng. 

35 [0087] A description of the Use of the embodiment in 
Fig. 2 as the system boot disk 
[0088] The following is a description of the system 
boot disk using the USB interface flash memory device 
based on Window 98/Me/200/XP operating systems. It 

40 is noted that the device can not only be used as the sys- 
tem boot disk for Window98/Me/2000/XP. but also suit- 
able for other operating systems. 
[0089] When the devk^e is used as the system boot 
disk, the boot program and the system programs of the 

45 operating system should firstly be stored in the device. 
Here is a description about how to make a system boot 
disk. 

1. Start Windows98/Me/2000/XP operating sys- 
50 tems; 

2. Set the storage disk status switch to "floppy disk 
drive"; 

3. Connect the devtee to the USB port of the host 
system; 

55 4. The related device driver program In the operat- 
ing system will recognize and operate the storage 
disk and a new icon and characters "floppy disk 
drive" will appear in the bon "My Computer". It is 
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noted that the device driver program provided Isy 
the manufacturer should be used if the system is 
Wlndows98. while under Windows l\Ae/2000/XP. de- 
fault device driver programs contained In the oper- 
ating system can be used; 
5. Forniat the floppy disk as a system boot disk and 
copy the con^esponding files to the floppy disk, l.e., 
the system boot disk is produced. 

[0090] When the making of the system boot disk is 
finished, the device can be used as the disk to boot the 
system. The following is a description about how to use 
the boot disk. 

[0091] The use of the boot disk 

1 . Tum on the power of the host computer. 

2. Enter the BIOS setting of the system and check 
the "bootable system device" item, if it is not set as 
the USB Floppy Disk Drive, that is. the USB external 
floppy disk (the initial setting of the system may be 
a Legacy Roppy), then it is modified to USB Floppy 
Disk Drive. Saving the modified setting to the BIOS 
and exiting from the setting of the BIOS and restart 
the host computer machine. 

3. Meanwhile, put the storage disk status switch of 
the devk:e to a status 'floppy disk drive" and con- 
nects the device to the USB port of the host com- 
puter machine. 

4. in the booting process of the host system, BIOS 
will recognize the storage disk and reads the oper- 
ating system boot program and the system pro- 
grams stored on the storage device. Then the cor- 
responding programs are executed and the operat- 
ing system is loaded. 

5. The booting of the system is completed. 

[0092] A description of the use of the embodiment in 
Fig. 2 as a large capacity storage disk 
[0093] The following is a description of the USB inter- 
face flash memory storage device used as a large ca- 
pacity storage disk based on Windows 98/N/le/2000/XP 
operating system. It Is noted that the device can not only 
run for Windows 98/Me/2000/XP as a large capacity 
disk but also suitabte for other operating systems as a 
large capacity disk. 

1. Start Wlndows9a/IVIe^000/XP operating sys- 
tems. 

2. Set the storage disk status switch to the status at 
"large capacity disk". 

3. Connect the devk^e to the USB port of the host 
system. 

4. The related device driver program in the operat- 
ing system will recognize and operate the storage 
disk and a new icon and characters 'removable 
disk" will appear in the icon "My Computer", it is not- 
ed that the devne driver program provided by the 
manufacturer should be used If the operating sys- 



tem is Windows98, while the operating system is 
one of Windows Me/2000/XP, the default device 
driver programs contained the operating system 
can be used. 

5 5. From now on reading and writing operations of 
the flies can be carried on the large capacity disk. 



Claims 

10 

1. A multifunction semiconductor storage device ca- 
pable of hot plug and play and being removable 
connected to the host system through the general 
purpose Interface, including a semiconductor stor- 
es age media module (1 ) and a controller module (2), 

wherein the controller module (2) comprises a gen- 
eral purpose Interface control module (21 ), a micro- 
processor and control module (22), said semicon- 
ductor storage device can realize the devtee class 

^ protocol of the floppy disk drive, simulate and im- 
plement the storing function of the floppy diskette 
working on the floppy disk drive, or realize the de- 
vice class protocol of the CD-ROM drive, simulate 
and Implement the storing function of the CD-ROM 

25 working on the CD-ROM drive, or realize the devtoe 
class protocol of the ZIP disk, simulate and Imple- 
ment the storing function of the ZIP disk, or realize 
the device class protocol of the MO disk, simulate 
and implement the storing function of the MO disk. 

30 

2. A multifunction semiconductor storage device as 
claimed in claim 1 , wherein the semiconductor stor- 
age media module (1) corresponds to a storage 
space or can be divided into at least two storage 

35 spaces. 

3. A multifunction semfconductor storage device as 
claimed in claim 1 , wherein it can be recognized, 
controlled and accessed by the BIOS (Basic Input 

40 and Output System) of the host computer, the sem- 
k:onductor storage media module (1) stores the 
boot up program of the operating system and oper- 
ating system programs, while the BIOS of the host 
computer Is powered up, the boot up program of the 

45 operating system and operating system programs 
are loaded from the semiconductor storage media 
module (1) so as to boot the host computer. 

4. A multifunction sembonductor storage devk^e as 
so claimed in claim 1 , wherein the driver programs of 

the semiconductor storage devrce can be stored in 
the semiconductor storage media module (1) so as 
to realize the functk)n of storing the driver program 
in Itself. 

55 

5. A multifunction semiconductor storage device as 
claimed in claim 1 , wherein further includes a write 
protect switch (3) capable of offering physical pro- 
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tection to said semiconductor storage media mod- 
ule (1) so as to prevent the contents from being 
overwritten or erased, said write protect switch (3) 
is electrically connected to said microprocessor and 
control module (22). 

6. A muttifunction semiconductor storage device as 
claimed In claim 1 , wherein further includes a LED 
indicator (5) comprising one or a plurality of indica- 
tor devices which can show the status of the semi- 
conductor storage device, said LED power indicator 
(5) is electrically connected to the microprocessor 
and control module (22) electrically. 

7. A multifunction semiconductor storage device as 
claimed in claim 1 , wherein said controller module 
(2) further includes a buffer module (23). said buffer 
module (23) Is a static random access memory 
(SRAM) and is electrically connected to the micro- 
processor and control module (22). 

8. A multifunction semiconductor storage device as 
claimed In claim 1 , wherein said semiconductor 
storage media module (1) has a buffer area. 

9. A muttifunction semiconductor storage device as 
claimed in claim 1, wherein said semiconductor 
storage media module (1 ) has a special inforrriation 
area for storing the infomation relevant to said 
semiconductor storage device, the password and 
the digital signature of the user 

10. A muttifunction semiconductor storage device as 
claimed in claim 2, wherein each of the storage 
spaces of said semiconductor storage media mod- 
ule (1) con-esponds to a storage disk. 

11. A multifunction semiconductor storage device as 
clahned in daim 1 0, wherein said storage disk can 
be a simulated floppy disk drive and floppy diskette, 
a simulated CD-ROM drive and a CD-ROM, a sim- 
ulated hard disk, a smnulate ZIP disk, a simulated 
MO disk, or a customized storage disk. 

12. A multifunction semiconductor storage device as 
claimed in claim 1 0, wherein further Includes a stor- 
age disk selection switch (4) for selecting at least 
one storage disk from ad storage disks, so that the 
selected storage disk can be recognized, controlled 
and accessed by the host computer. 

13. A muttifunction semiconductor storage device as 
claimed in claim 10, wherein said storage disl( sup- 
ports the device class protocols such as UFI (USB 
Floppy Interface) protocol, SFF80201 protocol, 
SFF80701 protocol, SCSI Transparent Command 
Set protocol, Reduced Block Commands (RBC) 
T10 PrDje<^1240-D protocol, ZIP disk protocol and 



MO disk protocol. 

14. A muttifunction semkx)nductor storage device as 
claimed in claim 10, wherein each of the storage 

5 disks can be divided into smaller storage spaces in- 
cluding the data area and the special infomiation 
area, the special information contained in said spe- 
cial information area includes information related to 
the storage disk, the password and the digital sig- 

10 nature of the user. 

15. A method for booting up computer using the multi- 
function semiconductor storage device, comprising 
the steps of: 

15 

storing the boot program of the operating sys- 
tem and operating system programs into the 
multifunction semiconductor storage devtoe; 
connecting the multifunction semiconductor 
storage device with the computer host system 
through the general-purpose interface; 
identifying the general purpose interface, and 
controlling and readingAwriting the muttifunc- 
tion semiconductor storage device based on 
BIOS after powered up the computer host sys- 
tem; and 

loading the boot program of the operating sys- 
tem and operating system programs stored in 
the multifunction semiconductorstorage device 
to computer host system for achieving compu- 
ter boot-up. 
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